二叉树是一种极其重要的数据结构,以下是二叉树的结构定义 创建 和递归先序 中序 后序 遍历的代码.
#include<stdio.h>
#include<stdlib.h>
typedef char ElemType;
/*二叉树节点数据结构*/
typedef struct node{
ElemType data;
struct treenode *lChild;
struct treenode *rChild;
} TreeNode;
/*使用先序遍历创建二叉树*/
TreeNode *createBiTreeInPreOrder(){
ElemType ch;
TreeNode *T;
scanf("%ch", &ch); //这样调用scanf函数时,树的节点一次全部输入,如果要一次输入一个的话,那么在格式化字符串%ch前面加上空格即可
if(ch != '#'){
T = (TreeNode *)malloc(sizeof(TreeNode));
if(T == NULL){
printf("内存空间不足,程序退出\n");
exit(-1);
}
T->data = ch;
T->lChild = createBiTreeInPreOrder();
T->rChild = createBiTreeInPreOrder();
} else{
T = NULL;
}
return T;
}
/*使用中序遍历创建二叉树*/
TreeNode *createBiTreeInInOrder(){
ElemType ch;
TreeNode *T;
scanf("%ch", &ch); //这样调用sca